事件
事件其实是包含“事件”与“触发器”2个部分。你可以在任意对象上以某个事件名注册触发器,当该对象以该事件发起出事件时,便会被触发器接收到。发起事件时可以传入N个自定义参数,这些参数会被触发器接收到。你可以给同一个对象的某个事件名下注册多个触发器,当发起事件时,这些触发器会按照注册顺序反序执行。在这些触发器依次执行的过程中,删除一个还在排队等待执行的触发器,那么它将不会执行;新建该事件名的触发器,那么它本次也不会执行。
-- 发起一个事件,自定义参数为...
base.event_notify(obj, name, ...)
-- 也可以用这个方法来发起事件,区别之后再讲
base.event_dispatch(obj, name, ...)
-- 这个事件会被该触发器接收到
base.event_register(obj, name, function (trigger, ...)
-- 接收到的自定义参数为...
end)
为了方便起见,我们将一些常用对象做了封装
全局事件。
-- 发起
base.game:event_notify(name, ...)
base.game:event_dispatch(name, ...)
-- 接收
base.game:event(name, function (trigger, ...)
end)
技能事件,技能事件发起完毕后会使用同样的参数再发起一次全局事件。
-- 发起
skill:event_notify(name, ...)
skill:event_dispatch(name, ...)
-- 接收
skill:event(name, function (trigger, ...)
end)
base.game:event(name, function (trigger, ...)
end)
状态事件,状态事件发起完毕后会使用同样的参数再发起一次全局事件。
-- 发起
buff:event_notify(name, ...)
buff:event_dispatch(name, ...)
-- 接收
buff:event(name, function (trigger, ...)
end)
base.game:event(name, function (trigger, ...)
end)
玩家事件,玩家事件发起完毕后会使用同样的参数再发起一次全局事件。
-- 发起
player:event_notify(name, ...)
player:event_dispatch(name, ...)
-- 接收
player:event(name, function (trigger, ...)
end)
base.game:event(name, function (trigger, ...)
end)
单位事件,玩家事件发起完毕后会使用同样的参数再发起一次玩家事件和一次全局事件,发起玩家事件时玩家为单位的控制者。
-- 发起
unit:event_notify(name, ...)
unit:event_dispatch(name, ...)
-- 接收
unit:event(name, function (trigger, ...)
end)
unit:get_owner():event(name, function (trigger, ...)
end)
base.game:event(name, function (trigger, ...)
end)
event_notify与event_dispatch的区别在于,event_dispatch
可以获取到触发器的返回值:当接收事件的触发器返回了一个非nil
的值后,当前事件将被终止,并将返回值返回给event_dispatch
的调用方。而event_notify
的事件则无法被终止,也不关心返回值。
base.game:event('加法', function (trigger, a, b)
return a + b
end)
local result = base.game:event_dispatch('加法', 1, 2)
print(result) --> 3